home *** CD-ROM | disk | FTP | other *** search
/ Go64! / Go64_2000-11_2000_CSW_Side_B.d64 / race track (.txt) < prev    next >
Commodore BASIC  |  2023-02-26  |  9KB  |  280 lines

  1. 10 rem"     [210]ennbahn [214]2.11
  2. 11 [143]"*************************
  3. 12 rem"     (w) by [212].[194]aade
  4. 13 [143]"   02/1999 - 08/2000
  5. 14 rem"         email :
  6. 15 [143]" torsten@sport/moeller.de
  7. 16 rem"*************************
  8. 17 [143]
  9. 40 g[178][194](186): [143]" # of ascloppy
  10. 45 em=58:       rem" # of interrupts
  11. 50 w[178]0.7:       [143]" loop waiting time
  12. 60 a=peek(53433)and128
  13. 61 rem" [211][195][208][213] enabled ?
  14. 62 [139] a[178]128 [167] 70:[143]" no (NULL)len(NULL)(NULL)
  15. 63 poke53374,0:poke53366,0:poke53375,0
  16. 64 rem" optimize [211][195][208][213] for [194][193][211][201][195]
  17. 65 [151] 53371,0:[143]" (NULL)len(NULL)(NULL) -> 20(NULL)left$z
  18. 66 print"[211][195][208][213] found ..."
  19. 70 if peek(49153)=173 then 90
  20. 71 rem" [212][201][205][197][210]  allways loaded
  21. 72 [153]"loading (NULL)right$(NULL)val(NULL)-(NULL)2 ..."
  22. 80 [143]" load interrupt routine
  23. 83 sys 57812("timer-v2"),g,1
  24. 84 poke780,0
  25. 85 sys 65493
  26. 86 rem" wit this [211][217][211]'s you can load new    program parts witout new start
  27. 90 [151] 56325,em:[143]" # right$nterrupts                             default=58
  28. 95 sys 49152:    rem" init                                    interrupt routine
  29. 100 [141] 1100:  [143]" init program
  30. 101 poke53370,0:rem" [211][195][208][213] -> 1 [205][200]z
  31. 102 [153]"start main program ..."
  32. 103 a[178]100:[141] 1000:[143]" sound
  33. 104 for l=0 to w*200:next
  34. 105 a=160:gosub 1000
  35. 106 for l=0 to w*200:next
  36. 107 a=70:gosub 1000:forl=0tow*300:next
  37. 108 poke 53771,0:rem" [211][195][208][213] -> 20 [205][200]z
  38. 110 [143]" main program *****************
  39. 120 gosub 1200: rem" init screen
  40. 130 [141] 1400: [143]" driver/# of laps
  41. 140 poke49242,255:rem"1/10'' interim1
  42. 150 [151]49245,255:[143]"1/10'' interim2
  43. 160 poke49236,255:rem"1/10'' driver1
  44. 165 [151]49239,255:[143]"1/10'' driver2
  45. 167 rem" if content=255, then no switch          was actuated
  46. 170 l%(1)[178][171]1:l%(2)[178][171]1:[143]"                      always no lap driven
  47. 175 zb%(1)=32767:zb%(2)=32767:rem"              reset best time
  48. 180 zr%(1)[178]0:zr%(2)[178]0:[143]"                      reset lap time
  49. 190 gosub 2000: rem" ready-steady-go!
  50. 195 [161] a$:[143]" reset key buffer
  51. 200 gosub 3000: rem" the [210][193][195][197]
  52. 900 [153]"stop         another race  (j/n) ?        wait"
  53. 910 [161] a$
  54. 920 [139] [168](a$[178]"j" [176] a$[178]"n" [176] a$[178]"y")[167] 910
  55. 930 [139] a$[178]"n" [167] 1900:[143]" the end...
  56. 980 goto 110
  57. 1000 rem "make sound --> a - frequency
  58. 1010 [151] 54296,15:[151]54273,a:[151]54277,9
  59. 1020 [151]54278,9:[151]54276,17:[151]54276,16
  60. 1030 [142]
  61. 1100 [143]"   init screen
  62. 1110 print"[158]":rem" clear screen,           print mode, ink color
  63. 1120 [151]53280,11:[151]53281,11:[143]"          background/frame color
  64. 1130 dim po$(2):rem"left/right - 1/2
  65. 1140 po$(1)[178]""
  66. 1141 po$(2)[178]""
  67. 1150 s1$[178]"player1"
  68. 1151 s2$[178]"player2"
  69. 1152 l0%[178]3
  70. 1170 [151] 56579,255:[143]" init (NULL)(NULL)val(NULL)(NULL)(NULL)(NULL)(NULL)
  71. 1180 gosub 1600:rem" power [207][206]
  72. 1190 [142]
  73. 1200 [143]"print on screen
  74. 1210 poke53280,11:rem" frame color
  75. 1270 [153]"loadsys  *****     (NULL)atnlenval (NULL)(NULL)atnlen(NULL) (NULL)2.11     *****  "
  76. 1280 [153] "     driver 1:   sys laps   driver 2:sys"
  77. 1290 [153] "     lap time :          lap time :"
  78. 1295 [153] "     interim 1:          interim 2:"
  79. 1300 [153] "      driven :            driven :"
  80. 1310 [153] "      to go  :            to go  :"
  81. 1320 [153] "     total time          total time"
  82. 1330 [153] "     best time:          best time:"
  83. 1390 [142]
  84. 1400 [143] "enter drivers & # of laps
  85. 1410 print "";po$(1);"  ";s1$
  86. 1420 print "[144]";po$(1);
  87. 1430 input s1$
  88. 1440 s3$=right$("          "+s1$,int((10-len(s1$))/2)+len(s1$))
  89. 1450 print "[144]";po$(1);"     [157][157][157][157][157]";s3$;"     "
  90. 1460 print "";po$(2);"  ";s2$
  91. 1470 print "[144]";po$(2);
  92. 1480 input s2$
  93. 1490 s4$=right$("          "+s2$,int((10-len(s2$))/2)+len(s2$))
  94. 1500 print "[144]";po$(2);"     [157][157][157][157][157]";s4$;"     "
  95. 1510 print"";l0%
  96. 1520 print"";
  97. 1530 input a$
  98. 1540 if val(a$)<1 or val(a$)>99 then 1510
  99. 1550 l0%=val(a$):ru%=l0%
  100. 1560 print"      [157][157][157][157]";l0%
  101. 1590 return
  102. 1600 rem" power [207][206]
  103. 1610 [143]" (NULL)elais at cassette port
  104. 1620 poke192,0:poke1,peek(1)and39
  105. 1630 rem" [210]elais at [213][211][197][210] [208]ort
  106. 1640 [151] 56577,255
  107. 1695 [142]
  108. 1700 [143]" power (NULL)ascasc
  109. 1710 rem" [210]elais at cassette port
  110. 1720 [151]192,1:[151]1,[194](1)[176]32
  111. 1730 [143]" (NULL)elais at (NULL)(NULL)val(NULL) (NULL)ort
  112. 1740 poke 56577,0
  113. 1795 return
  114. 1900 rem" end program
  115. 1910 [158] 49220:[143]" reset (NULL)right$(NULL)val(NULL)-(NULL)2
  116. 1920 poke 56325,58:rem" reset # [201][210][209]
  117. 1930 [151]53280,6:[151]53281,6:[143]"            reset colors
  118. 1935 gosub 1600:rem" power [207][206]
  119. 1940 [153]"load"
  120. 1945 [151] 53370,0:[143]" (NULL)len(NULL)(NULL) -> 1(NULL)left$z
  121. 1950 a=110:gosub 1000
  122. 1955 for l=0 to w*100:next
  123. 1960 a=60:gosub 1000
  124. 1965 for l=0 to w*100:next
  125. 1970 a=160:gosub 1000
  126. 1975 for l=0 to w*100:next
  127. 1980 a=100:gosub 1000
  128. 1985 poke 53371,0:rem" [211][195][208][213] -> 20[205][200]z
  129. 1990 [128]
  130. 2000 [143]" (NULL)eady, (NULL)teady, chr$(NULL)!
  131. 2005 gosub 1700:rem" power [207][206]
  132. 2010 [151] 53370,0:[143]" (NULL)len(NULL)(NULL) -> 1(NULL)left$z
  133. 2020 poke 53280,6:rem" frame color
  134. 2030 [153]"prepare for race"
  135. 2040 a[178]100:[141] 1000:[143] "sound
  136. 2050 for l=0 to w*2000:next:rem" wait
  137. 2060 [151] 53280,7:[143]"change frame color
  138. 2070 print"        [210][197][193][196][217]!      "
  139. 2080 a=80:gosub1000:rem "sound
  140. 2090 [129] l[178]0 [164] w[172]5000:[130]:[143]"wait
  141. 2100 poke 53280,2:rem" frame color
  142. 2110 [153]"       (NULL)(NULL)valatnstr$(NULL)!      "
  143. 2120 a[178]90:[141]1000:[143] "sound
  144. 2130 for l=0 to w*3000:next:rem"wait
  145. 2140 [151] 53280,5
  146. 2150 [153]"        chr$(NULL) !      wait"
  147. 2160 a[178]120:[141]1000:[143] "sound
  148. 2170 poke 53371,0:rem" [211][195][208][213] -> 20[205][200]z
  149. 2180 [141] 1600:[143]" power (NULL)(NULL)
  150. 2190 return
  151. 3000 rem" [210]ace (two [208]layer + interim)
  152. 3010 [143]" determine start time:
  153. 3020 get a$
  154. 3025 if a$<>"" then return: rem" stop
  155. 3030 [139] [194](49236)[178]255 [167] 3100:[143]"          driver1 did not started yet
  156. 3040 t%=peek(49236):rem" 1/10
  157. 3042 s%[178][194](49235):[143]" (NULL)econds
  158. 3044 m%=peek(49234):rem" [205]inutes
  159. 3046 [141] 4700:[143]" total time in 1/10
  160. 3050 z0%=z%: rem" [205]astertime
  161. 3070 zl%(1)[178]z0%:zl%(2)[178]z0%
  162. 3080 [137] 3200
  163. 3100 [139] [194](49239)[178]255 [167] 3190:[143]"          driver2 did not started yet
  164. 3110 t%=peek(49239):rem" 1/10
  165. 3112 s%[178][194](49238):[143]" (NULL)econds
  166. 3114 m%=peek(49237):rem" [205]inutes
  167. 3116 [141] 4700:[143]" total time in 1/10
  168. 3120 z0%=z%: rem" [205]astertime
  169. 3140 zl%(2)[178]z0%:zl%(1)[178]z0%
  170. 3150 [137] 3200
  171. 3190 [137] 3010:[143]" (NULL)tart did not                           happened yet
  172. 3200 rem" [211]tart always done
  173. 3300 [143]" right$nterims ?
  174. 3305 rem" [208]layer 1
  175. 3310 [139] [194](49242)[178]255 [167] 3410:[143]"            driver1 no interim
  176. 3320 t%=peek(49242):rem" 1/10
  177. 3322 s%[178][194](49241):[143]" (NULL)econds
  178. 3324 m%=peek(49240):rem" [205]inutes
  179. 3326 [141] 4700:[143]" total time 1/10
  180. 3330 g=z%-zl%(1):rem" time diference                     to last finis line
  181. 3340 [141] 4900:[143]" change to m$s$t$
  182. 3350 print"";po$(1);g$
  183. 3360 poke 49242,255:rem" reset time
  184. 3400 [143]" (NULL)layer 2
  185. 3410 if peek(49245)=255 then 3500:rem"            [208]layer 2 no interim
  186. 3420 t%[178][194](49245):[143]" 1/10
  187. 3422 s%=peek(49244):rem" [211]econds
  188. 3424 m%[178][194](49243):[143]" (NULL)inutes
  189. 3426 gosub 4700:rem" total time 1/10
  190. 3430 g[178]z%[171]zl%(2):[143]" str$ifference to last                 finish line
  191. 3440 gosub 4900:rem" [195]hange to m$s$t$
  192. 3450 [153]"";po$(2);g$
  193. 3460 [151] 49245,255:[143]" reset time
  194. 3500 rem" [198]inish line ?
  195. 3505 [143]" (NULL)pieler 1
  196. 3510 if peek(49236)=255 then 3710:rem"            [208]layer 1 not
  197. 3515 [139] f1%[178]1 [167] 3690:[143]"permanent                               contact
  198. 3520 t%=peek(49236):rem" 1/10
  199. 3522 s%[178][194](49235):[143]" (NULL)ekunden
  200. 3524 m%=peek(49234):rem" [205]inuten
  201. 3526 [141] 4700:[143]" total time 1/10                         (t%, s%, m% -> z%)
  202. 3530 l%(1)=l%(1)+1:rem" lap driven
  203. 3540 zr%(1)[178]z%[171]zl%(1):[143]" lap time
  204. 3545 if l%(1)>l0% then 3590:rem" all                 laps driven
  205. 3550 zg%(1)[178]z%[171]z0%:[143]" (NULL)otal time
  206. 3560 if(zr%(1)<zb%(1)and l%(1)>0)then zb%(1)=zr%(1):rem" new best time
  207. 3590 zl%(1)[178]z%
  208. 3600 [143]" print on screen
  209. 3610 g=zr%(1):gosub 4900:rem" [195]hange                                  (g -> g$)
  210. 3620 [153]"";po$(1);g$
  211. 3625 g[178]0:[141] 4900:[143]" reset interim
  212. 3626 print"";po$(1);g$
  213. 3630 print"";po$(1);"      [157][157][157]";l%(1)
  214. 3640 print"";po$(1);"      [157][157][157]";l0%-l%(1)
  215. 3650 g=zg%(1):gosub 4900:rem" [195]hange
  216. 3660 [153]"";po$(1);g$
  217. 3670 [139] l%(1)[178]0 [167] 3690:[143]"no                                      best time
  218. 3672 g=zb%(1):gosub 4900:rem" change
  219. 3680 [153]"";po$(1);g$
  220. 3690 [151]49236,255:[143]" 1/10 'clear'
  221. 3692 poke53370,0:poke56325,1:wait 56325,1:poke53371,0:poke56325,em
  222. 3693 rem" wait for interrupt
  223. 3695 [139] [194](49236)[179]255 [167] f1%[178]1:[137] 3700:[143]" permantent contact
  224. 3697 f1%=0:rem" no permanent contact
  225. 3700 [143]" (NULL)layer 2
  226. 3710 if peek(49239)=255 then 4000:rem"            [208]layer 2 no finish
  227. 3715 [139] f2%[178]1 [167] 3890:[143]"permanent                               contact
  228. 3720 t%=peek(49239):rem" 1/10
  229. 3722 s%[178][194](49238):[143]" (NULL)ekunden
  230. 3724 m%=peek(49237):rem" [205]inuten
  231. 3726 [141] 4700:[143]" total time 1/10
  232. 3730 l%(2)=l%(2)+1:rem" lap driven
  233. 3740 zr%(2)[178]z%[171]zl%(2):[143]" lap time
  234. 3745 if l%(2)>l0% then 3790:rem" all                laps driven
  235. 3750 zg%(2)[178]z%[171]z0%:[143]" total time
  236. 3760 if(zr%(2)<zb%(2)and l%(2)>0)then zb%(2)=zr%(2):rem" new best time
  237. 3790 zl%(2)[178]z%
  238. 3800 [143]" print to screen
  239. 3810 g=zr%(2):gosub 4900:rem" [195]hange
  240. 3820 [153]"";po$(2);g$
  241. 3825 g[178]0:[141] 4900:[143]" reset interim
  242. 3826 print"";po$(2);g$
  243. 3830 print"";po$(2);"      [157][157][157]";l%(2)
  244. 3840 print"";po$(2);"      [157][157][157]";l0%-l%(2)
  245. 3850 g=zg%(2):gosub 4900:rem" [195]hange
  246. 3860 [153]"";po$(2);g$
  247. 3870 [139] l%(2)[178]0 [167] 3890:[143]"no                                      best time
  248. 3872 g=zb%(2):gosub 4900:rem" [195]ange
  249. 3880 [153]"";po$(2);g$
  250. 3890 [151]49239,255
  251. 3892 [151]53370,0:[151]56325,1:[146] 56325,1:[151]53371,0:[151]56325,em
  252. 3893 [143]" wait for interrupt
  253. 3895 if peek(49239)<255 then f2%=1:goto 4000:rem" permanent contact
  254. 3897 f2%[178]0:[143]" no permanent contact
  255. 4000 if(l%(1)=ru%)or(l%(2)=ru%)then poke 53280,6:ru%=-2:gosub 1000
  256. 4100 get a$:rem" cancel ?
  257. 4110 [139]((l%(1)[179]l0%)[176](l%(2)[179]l0%))[175](a$[178]"")[167] 3300:[143]" no end
  258. 4130 gosub1000
  259. 4140 return
  260. 4700 rem" calculate total time in 1/10            --> m%,s%,t% (normal-[198]ormat)
  261. 4701 [143]" <-- z%       (normal-ascormat)
  262. 4710 z%=m%*600
  263. 4711 rem" [205]inutes to 1/10
  264. 4720 z%[178]z%[170]s%[172]10
  265. 4721 [143]" (NULL)econds to 1/10                         and add
  266. 4730 z%=z%+t%
  267. 4731 rem" add 1/10
  268. 4790 [142]
  269. 4900 [143]" (NULL)inutes, (NULL)econds, 1/10             calculate from total 1/10
  270. 4901 rem" --> g
  271. 4902 [143]" <-- g$
  272. 4910 z=int((g/10-int(g/10))*10):rem"1/10
  273. 4920 g[178][181](g[173]10):[143]" sub 1/10
  274. 4930 s=int((g/60-int(g/60))*60):rem"sec
  275. 4940 m[178][181](g[173]60):[143]" (NULL)inutes
  276. 4950 g$=" "+right$(str$(m),2)+"m"
  277. 4960 g$=g$+right$(str$(s),2)+"."
  278. 4970 g$=g$+right$(str$(z),1)+"s"
  279. 4990 return
  280.